<!-- src/components/Icon.vue -->
<template>
  <!-- 合并外部 class -->
  <i
    :class="iconClass"
    :style="{ fontSize: size, color }"
    @click="$emit('click')"
    class="icon-comp"
  ></i>
</template>

<script>
export default {
  name: 'Icon',
  props: {
    // 图标名称，对应 iconfont 的类名（去掉 icon- 前缀）
    name: {
      type: String,
      required: true,
    },
    // 图标大小，支持 '16px'、'2em'、'2rem' 等
    size: {
      type: String,
      default: '16px',
    },
    // 图标颜色
    color: {
      type: String,
      default: 'inherit',
    },
    marginLeft: {
      type: String,
      default: '0px',
    },
    marginRight: {
      type: String,
      default: '0px',
    },
  },
  computed: {
    iconClass() {
      return [`iconfont`, `icon-${this.name}`];
    },
  },
};
</script>

<style scoped>
.icon-comp {
  font-style: normal;
  font-weight: normal;
  /* 提升渲染质量 */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
</style>
